ROLLING CODE SECURITY SYSTEM 

BACKGROUND OF THE INVENTION 

The invention relates in general to security- 
systems which allow operation upon the receipt of a proper- 
5 ly coded signal. More particularly, the invention relates 
to a security system or to a barrier operator system, such 
as a garage door operator, employing a transmitter and a 
receiver which communicate via code streams having at least 
a portion thereof which changes with multiple operation of 

10 the device. 

It is well known in the art to provide garage 
door operators or other barrier operators which include an 
electric motor connectable through a transmission to a door 
or other movable barrier which is to be opened and closed. 

15 Since many of these systems are associated with residences, 
as well as with garages, it is important that opening of 
the barrier be permitted only by one who is authorized to 
obtain entry to the area which the barrier protects. Some 
garage door operator systems have in the passed employed 

20 mechanical lock and key arrangements associated with elec- 
trical switches mounted on the outside of the garage. 
While these systems enjoy a relatively high level of secur- 
ity, they are very inconvenient to use for a person because 
it necessitates them exiting their vehicle in order to send 

25 the command to open the garage door. This also may present 
some danger to people when the exit the relative security 
of their vehicle if someone may be waiting to do injury to 
them. 

It is also well known to provide radio-controlled 
3 0 garage door operators which include a garage door operator 
unit having a radio receiver and a motor connected to be 
driven from the radio receiver. The radio receiver is 
adapted to receive radio frequency signals or other 
electromagnetic signals having particular signal character- 
35 istics which, when received, cause the door to be opened. 



More recently, such transmitter and receiver systems have 
become relatively more sophisticated in that they use radio 
transmitters which employ coded transmissions of multiple 
or three -valued digits, also known as "trinary bits" or 
other serial coded transmission techniques. Among these 
systems are U.S. Patent No. 3,906,348 to Willmott, which 
employs a transmitter and receiver system wherein a plural- 
ity of mechanical switches may be used to set a stored 
authorization code. 

U.S. Patent No. 4,529,980 to Liotine et al . dis- 
closes a transmitter and receiver combination for use in a 
device such as a garage door operator wherein the trans- 
mitter stores an authorization code which is to be trans- 
mitted to and received by the receiver via a radio 
frequency link. In order to alter or update the authori- 
zation code contained within the transmitter, the receiver 
is equipped with a programming signal transmitter or light 
emitting diode which can send a digitized optical signal 
back to the transmitter where it is stored. Other systems 
also employing encoded transmissions are U.S. Patents Nos. 
4,037,201, 4,535,333, 4,638,433, 4,750,118 and 4,988,992. 

While each of these devices have provided good 
security for the user, it is apparent that persons wishing 
to commit property or person- related crimes have become 
more sophisticated as well. It is known in the security 
industry today that devices are being made available that 
can intercept or steal rolling code. 

Transequatorial Technology, Inc. sells integrated 
circuit code hopping encoders identified as Keeloq Model 
NTQ105, NTQ115, NTQ125D and NTQ129. Some of the keeloq 
code hopping encoders generate serial codes having fixed 
portions, i.e., which do not change with repeated actuation 
o-f the encoding portion of the chip and rolling code por- 
tions which alter with each actuation of the encoding 
portion of the chip. in order to avoid, however, having 
the problem of the encoding portion of the chip having been 



inadvertently enabled and causing the rolling code to be 
altered on successive enabling attempts thereby leading to 
a rolling code which is transmitted and not recognized by 
a receiver, the keeloq code hopping encoders provide a 
window forward system, that is they are operable with 
systems having code receivers which recognize as a valid 
code not a single rolling code, but a plurality of rolling 
codes within a certain code window or window of values 
which are the values which would be generated on a rela- 
tively small number of switch closures as compared to the 
total number of rolling codes available. The problem with 
such a system, however, might arise if a user was away for 
a period of time or had inadvertently caused codes to be 
transmitted excluding the number of codes normally allowed 
within the valid forward code window. In that case, the 
rolling code would not be recognized by the receiver and 
the user could not gain entry without taking other measures 
to defeat the locking system or the garage door operator 
system which might involve the intervention of a trained 
engineer or technician. 

Texas Instruments also has a prior system identi- 
fied as the Mark Star TRC1300 and TRC1315 remote control 
transmitter/receiver combination. The system involves the 
use of a rolling code encoder which increments or rolls 
potentially the entire code, that is it does not leave a 
fixed portion. The system also includes a forward window- 
ing function which allows an authorized user to be able to 
cause the receiver to be enabled within a limited number of 
key pushes. Like the keeloq system, if the forward window 
is exceeded, the Texas Instruments system must be placed in 
a learn mode to cause the system to relearn the code. In 
order to place the system into the learn mode, the person 
must obtain direct access to the receiver to cause a pro- 
gramming control system associated with the receiver to be 
hand actuated causing the receiver to enter a learn mode. 
Once the receiver has learned the new code, the receiver 



will then construct a new valid forward code window within 
which valid rolling codes may be received. The problem, of 
course, with such a system is that if, for instance in a 
garage door operator, the only portal of entry to the 
5 garage door is through the overhead door controlled by the 
garage door operator, the user will not be able to obtain 
entry to the garage without possibly having to do some 
damage to the structure. This problem is sometimes 
referred to in the industry as a "vaulted garage." 

10 What is needed is an economical encoding system 

which provides good security by using a rolling code, but 
which enables a user of the system to proceed via a 
gradually degraded pathway in the event that the receiver 
detects a signal condition indicative of what might be a 

15 lack of security. 

SUMMARY OF THE INVENTION 

The invention relates in general to an electronic 
system for providing remote security for entry of actuation 
of a particular device. Such a system may include a trans - 

20 mitter and receiver set, for instance with a hand- held 
transmitter and a receiver associated with a vehicle such 
as an automobile or the like. The transmitter, upon 
signaling the receiver, causing the vehicle to start up or 
to perform other functions. The system may also be useful 

25 in a barrier operator system such as a garage door operator 
by allowing the garage door to be opened and closed in a 
relatively secure fashion while preventing persons who may 
be intercepting the radio frequency signals from being able 
to, although unauthorized, cause the vehicle to begin 

30 running or to allow access to the garage. 

The system includes a transmitter generally 
having means for developing a fixed code and a rolling or 
variable code. The rolling or variable code is changed 
with each actuation of the transmitter. The fixed code 
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remains the same for each actuation of the transmitter. In 
the present system, the transmitter includes means for pro- 
ducing a 32-bit frame comprising the fixed portion of the 
code and a second 32 -bit frame comprising the variable por- 
5 tion of the code. The 32 -bit rolling code is then mirrored 
to provide a 32 -bit mirrored rolling code. The 32 -bit 
mirrored rolling code then has its most significant bit 
"deleted" by setting it to zero. The transmitter then 
converts the 32 -bit fixed code and the mirrored variable 

10 code to a three -valued or trinary bit fixed code and a 
three -valued or trinary bit variable code or rolling code. 

To provide further security, the fixed code and 
the rolling codes are shuffled so that alternating trinary 
bits are comprised of a fixed code bit and a rolling code 

15 bit to yield a total of 40 trinary bits. The 40 trinary 
bits are then packaged in a first 20 -trinary bit frame and 
a second 20 -trinary bit frame which have proceeding them a 
single synchronization and/or identification pulse indi- 
cating the start of the frame and whether it is the first 

20 frame or the second frame. Immediately following each of 
the frames, the transmitter is placed into a quieting con- 
dition to maintain the average power of the transmitter 
over a typical 100 millisecond interval within legal limits 
promulgated by the United States Federal Communications 

25 Commission. The first trinary frame and the second trinary 
frame are used to modulate a radio frequency carrier, in 
this case via amplitude modulation to produce an amplitude 
modulated encrypted signal. In a preferred embodiment, the 
radio frequency signal is amplitude modulated. The ampli- 

30 tude modulated signal is then launched and may be received 
by an AM receiver. In the preferred embodiment, the AM 
receiver receives the amplitude modulated signal, demodu- 
lates it to produce a pair of trinary bit encoded frames. 
The trinary bits in each of the frames are converted on the 

35 fly to 2 -bit or half nibbles indicative of the values of 
the trinary bits which are ultimately used to form two 
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16 -bit fixed code words and two 16 -bit variable code words. 
The two 16-bit fixed code words are used as a pointer to 
identify the location of a previously stored rolling code 
value within the receiver. The two 16 -bit rolling code 
5 words are concatenated by taking the 16 -bit word having the 
more significant bits, multiplying it by 3 10 and then adding 
it to the second of the words to produce a 32 -bit encrypted 
rolling code. In order to make certain that if the trans- 
mitter was inadvertently actuated a number of times, the 
10 authorized user can still start his car or gain entry to 
his garage. The 3 2 -bit encrypted code is then compared via 
a binary subtraction with the stored rolling code. If the 
32 -bit code is within a window or fixed count, in the 
present embodiment 1000, the microprocessor produces an 
15 authorization signal which is then responded to by other 
portions of the circuit to cause the garage door to open or 
close as commanded. In the event that the code is greater 
than the stored rolling code, plus 1000, indicative of a 
relatively large number of incrementations, the user is not 
20 locked out of the garage, but is allowed to provide further 
signals or indicia to the receiver that he is an authorized 
user without any significant degradation of the security. 
This is done by the receiver entering an alternate mode 
requiring two or more successive valid codes to be 
25 received, rather than just one. If the two or more 
successive valid codes are received, the garage door will 
open. However, in order to prevent a person who has 
previously or recently recorded a recent valid code from 
being able to obtain access to the garage, a trailing 
30 window, in this case starting at a count of 300 less than 
the present stored count and including all code values 
between the present stored count and 300 less is compared 
to the received code. If the received code is within this 
backward window, the response of the system simply is to 
35 take no further action, nor to provide authorization during 



that code cycle on the assumption that the code has been 
purloined. 

Thus, the present system provides important 
advantages over the previous garage door operator systems 
and even previous rolling code systems. The system pro- 
vides a multiple segmented windowed system which provides 
a valid code window, a second relatively insecure code 
window in which two successive valid codes must be received 
and finally a window in which no valid codes are recognized 
due to the likelihood of the receiver having been stolen. 

It is a principal object of the present invention 
to provide a security system involving a radio frequency 
transmitter and receiver wherein multiple security condi- 
tions may exist requiring different levels of signal 
security. 

It is another object of the present invention to 
provide a secure radio transmitter receiver system which 
may rapidly and easily decode a relatively large code com- 
bination. 

Other advantages of the invention will become 
obvious to one of ordinary skill in the art upon a perusal 
of the following specification and claims in light of the 
accompanying drawings . 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a perspective view of an apparatus for 
moving a barrier or garage embodying the present invention; 

FIG. 2 is a block diagram of a transmitter for 
use with a garage door operator of FIG. 1; 

FIG. 3 is a block diagram of a receiver posi- 
tioned within a head unit of the garage door operator shown 
in FIG. i; 

FIG. 4 is a schematic diagram of the transmitter 
shown in FIG. 2; 



FIG. 5 is a schematic diagram of the receiver 
shown in FIG. 3; 

FIG. 6 is a timing diagram of signals generated 
by a portion of the transmitter; 

FIGS. 7A, B, and C are flow diagrams showing the 
operation of the transmitter; and 

FIGS. 8A, B, C, D, E and F are flow charts show- 
ing the operation of the receiver. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

Referring now to the drawings and especially to 
FIG. l, more specifically a movable barrier door operator 
or garage door operator is generally shown therein and 
includes a head unit 12 mounted within a garage 14. More 
specifically, the head unit 12 is mounted to the ceiling of 
the garage 14 and includes a rail 18 extending therefrom 
with a releasable trolley 20 attached having an arm 22 
extending to a multiple paneled garage door 24 positioned 
for movement along a pair of door rails 26 and 28. The 
system includes a hand-held transmitter unit 30 adapted to 
send signals to an antenna 32 positioned on the head unit 
12 and coupled to a receiver as will appear hereinafter. 
An external control pad 34 is positioned on the outside of 
the garage having a plurality of buttons thereon and 
communicate via radio frequency transmission with the 
antenna 32 of the head unit 12. 

An optical emitter 42 is connected via a power 
and signal line 44 to the head unit. An optical detector 
46 is connected via a wire 48 to the head unit 12. 

Referring now to FIG,. 2, the transmitter 30 is 
shown therein in general and includes a battery 70 
connected by a pushbutton switch 72 to a power supply 74 
which is coupled via leads 75 and 76 to a microcontroller 
78. The microcontroller 78 is connected by a serial bus 79 
to a non-volatile memory 80. An output bus 81 connects the 



microcontroller to a radio frequency oscillator 82. The 
microcontroller 78 produces coded signals when the button 
72 is pushed causing the output of the RF oscillator 82 to 
be amplitude modulated to supply a radio frequency signal 
at an antenna 83 connected thereto. More specifically, as 
shown in FIG. 5, details of the transmitter 3 0 are shown 
therein, including a plurality of switches 72. "When switch 
72 is closed, power is supplied through a diode 100 to a 
capacitor 102 to supply a 7.1 volt voltage at a lead 103 
connected thereto. A light emitting diode 104 indicates 
that the transmitter button has been pushed and provides a 
voltage to a lead 105 connected thereto. A Zener diode 106 
provides voltage regulation and causes the back biased 
diode 107 to cause the crystal 108 to be energized, thereby 
energizing the microcontroller 78, a Zilog 125C0113 8-bit 
microcontroller in this embodiment. The signal is also 
sent via a resistor 110 through a lead 111 to a P32 pin of 
the microcontroller 78. Likewise, when a switch 113 is 
closed, current is fed through a diode 114 to the lead 103 
also causing the crystal 108 to be energized, powering up 
the microcontroller at the same time that pin P33 of the 
microcontroller is pulled up. Similarly, when a switch 118 
is closed, power is fed through a diode 119 to the crystal 
108 as well as pull up voltage being provided through a 
resistor 120 to the pin P31. It should also be appreciated 
that pin P34 of the microcontroller is configured via a 
connection with the resistor 123 to be an RS232 input port 
124. 

The microcontroller is coupled via the serial bus 
79 to a chip select port, a clock port and a DI port to 
which and from which serial data may be written and read 
and to which addresses may be applied. As will be seen 
hereinafter in the operation of the microcontroller, the 
microcontroller 78 produces output signals at the lead 81, 
which are supplied to a resistor 125 which is coupled to a 
voltage dividing resistor 12 6 feeding signals to the lead 
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127. A 30 -nanohenry inductor 128 is coupled to an NPN 
transistor 129 at its base 130. The transistor 129 has a 
collector 131 and an emitter 132. The collector 131 is 
connected to the antenna 83 which, in this case, comprises 
a printed circuit board, loop antenna having an inductance 
of 25 -nanohenries, comprising a portion of the tank circuit 
with a capacitor 133, a variable capacitor 134 for tuning, 
a capacitor 135 an a capacitor 136. An 30-nanohenry induc- 
tor 138 is coupled via a capacitor 139 to ground. The 
capacitor has a resistor 140 connected in parallel with it 
to ground. When the output from lead 81 is driven high by 
the microcontroller, the capacitor Qi is switched on 
causing the tank circuit to output a signal on the antenna 
83. When the capacitor is switched off, the output to the 
drive the tank circuit is extinguished causing the radio 
frequency signal at the antenna 83 also to be extinguished. 

Referring now to FIG. 3, the receiver is shown 
therein and includes a receiver antenna 200 coupled to an 
amplitude modulated receiver 2 02 driven from a power supply 
204 connectable to a source of alternating current 206. 
The receiver 202 provides a demodulated output via a band- 
pass filter 210 to an analog- to- digital converter 212 which 
provides input to a microcontroller 214 having an internal 
read-only memory 216 and an internal random-access memory 
218. A serial non-volatile memory 220 is connected via a 
memory bus 222 to the microcontroller 214 to send and 
receive information thereto. The microcontroller has an 
output line 226 coupled to a motor controller 228 which may 
include a plurality of relays or other standard electro- 
mechanical features which feeds electrical current on lines 
230 and 232 to an electric motor 234. 

Referring now to FIG. 3 the antenna 2 00 coupled 
to a reactive divider network 250 comprised of a pair of 
series connected inductances 252 and 254 and capacitors 256 
and 258 which supply an RF signal to a buffer amplifier 
having an NPN transistor 260, at its emitter 261. The NPN 
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transistor 260 has a pair of capacitors 262 and 264 
connected to it for power supply isolation. The buffer 
amplifier provides a buffered radio frequency output signal 
on a lead 268. The buffered RF signal is fed to an input 

2 70 which forms part of a super- regenerative receiver 272 
having an output at a line 274 coupled to the bandpass 
filter which provides digital output to the bandpass filter 
212. The bandpass filter 212 includes a first stage 276 
and a second stage 2 78 to provide a digital level output 
signal at a lead 280 which is supplied via an averaging 
circuit 282 to an input pin P32 of the microcontroller 214. 

The microcontroller 214 may have its mode of 
operation controlled by a programming or learning switch 

3 00 coupled via a line 3 02 to the P25 pin. A command 
switch 304 is coupled via a jumper 306 to a line 308 and 
ultimately through a resistor to the input pin P22. A pin 
P21 sinks current through a resistor 314 connected to a 
light emitting diode 316, causing the diode to light to 
indicate that the receiver is active. The microcontroller 
214 has a 4 MHz crystal 328 connected to it to provide 
clock signals and includes an RS232 output port 332 that is 
coupled to the pin P31. A switch 34 0 selects whether con- 
stant pressure or monostable is to be selected as the out- 
put from output terminals P24 and P23 which are coupled to 
a transistor 350 which, when switched on, sinks current 
through a coil 352 of a relay 354, causing the relay to 
close to provide an actuating signal on a pair of leads 356 
and 358 to an electric motor. 

It may be appreciated that the power supply 2 04 
may receive power from an external transformer or other AC 
source through a jack 370 which is connected to a pair of 
RJ uncoupling capacitors 372 and 374. The input signal is 
then set to a full-wave rectifier bridge 376 which provides 
an output current at a resistor 3 78. An 18 -volt Zener 
diode 3 80 is connected between ground and the resistor 3 78 
and includes high frequency bypass capacitor 382 connected 



in parallel with it. An 8. 2 -volt Zener diode 384 is 
connected in back-biased configuration to the resistor 378 
to receive a signal therefrom to guarantee that at least an 
8.2-volt signal is fed to a resistor 390 causing an LED 392 
to be illuminated and also causing power to be supplied to 
a 5 -volt 78L05 voltage regulator 396. The voltage regula- 
tor 396 supplies regulated voltage to an output line 398. 
Filtering capacitors 400a, 400b, 400c and 400d limit the 
fluctuations at the power supply. 

The program code listing for the transmitter is 
set forth at pages A-l through A- 19 and for the receiver at 
pages A- 2 0 through A- 51 of the attached appendix. 
Referring now to FIGS. 7A through 7C, the flow chart set 
forth therein describes the operation of the transmitter. 
A rolling code is incremented by three in a step 500, 
followed by the rolling code being stored for the next 
transmission from the transmitter when the transmitter 
button is pushed. The order of the binary digits in the 
rolling code is inverted or mirrored in a step 504, follow- 
ing which in a step 5 06, the most significant digit is 
converted to zero effectively truncating the binary rolling 
code. The rolling code is then changed to a trinary code 
having values 0, 1 and 2 and the initial trinary rolling 
code is set to 0. It may be appreciated that it is trinary 
code which is actually used to modify the radio frequency 
oscillator signal and the trinary code is best seen in FIG. 
6. It may be noted that the bit timing in FIG. 6 for a 0 
is 1.5 milliseconds down time and 0.5 millisecond up time, 
for a 1, l millisecond down and 1 millisecond up and for a 
2, 0.5 millisecond down and 1.5 milliseconds up. The up 
time is actually the active time when carrier is being 
generated. The down time is inactive when the carrier is 
cut off. The codes are assembled in two frames, each of 20 
trinary bits, with the first frame being identified by a 
0.5 millisecond sync bit and the second frame being identi- 
fied by a 1.5 millisecond sync bit. 



In a step 510, the next highest power of 3 is 
subtracted from the rolling code and a test is made in a 
step 512 to determine if the result is equal to zero. If 
it is, the next most significant digit of the binary roll- 
ing code is incremented in a step 514, following which flow 
is returned to the step 510. If the result is not greater 
than 0, the next highest power of 3 is added to the rolling 
code in the step 516. In the step 518, another highest 
power of 3 is incremented and in a step 520, a test is 
determined as to whether the rolling code is completed. If 
it is not, control is transferred back to step 510. If it 
has, control is transferred to step 522 to clear the bit 
counter. m a step 524, the blank timer is tested to 
determine whether it is active or not. If it is not, a 
test is made in a step 52 6 to determine whether the blank 
time has expired. if the blank time has not expired, 
control is transferred to a step 528 in which the bit 
counter is incremented, following which control is trans- 
ferred back to the decision step 524. if the blank time 
has expired as measured in decision step 526, the blank 
timer is stopped in a step 530 and the bit counter is 
incremented in a step 532. The bit counter is then tested 
for odd or even in a step 534. If the bit counter is not 
even, control is transferred to a step 53 6 where the output 
bit of the bit counter divided by 2 is fixed. If the bit 
counter is even, the output bit counter divided by 2 is 
rolling in a step 538. The bit counter is tested to deter- 
mine whether it is set to equal to 80 in a step 540. If it 
is, the blank timer is started in a step 542. If it is 
not, the bit counter is tested for whether it is equal to 
40 in a step 544. if it is, the blank timer is tested and 
is started in a step 544. If the bit counter is not equal 
to 40, control is transferred back to step 522. 

Referring now to FIGS. 8A through 8F and, in 
particular, to FIG. 8A, the operation of the receiver is 
set forth therein. In a step 700, an interrupt is detected 



- 14 - 

and acted upon from the radio input pin. The time differ- 
ence between the last edge is determined and the radio 
inactive timer is cleared in step 702. A determination is 
made as to whether this is an active time or inactive time 
5 in a step 704, i.e., whether the signal is being sent with 
carrier or not. If it is an inactive time, indicating the 
absence of carrier, control is transferred to a step 706 to 
store the inactive time in the memory and the routine is 
exited in a step 708. In the event that it is an active 

10 time, the active time is stored in memory in a step 710 and 
the bit counter is tested in a step 712. If the bit 
counter zero, control is transferred to a step 714, as may 
best be seen in FIG. 8B and a test is made to determine 
whether the inactive time is between 2 0 milliseconds and 

15 55 milliseconds. If it is not, the bit counter is cleared 
as well as the rolling code register and the fixed code 
register in step 716 and the routine is exited in step 718. 

In the event that the inactive time is between 
20 milliseconds and 55 milliseconds, a test is made in a 

20 step 720 to determine whether the active time is greater 
than 1 millisecond, as shown in FIG. 8C. If it is not, a 
test is made in a step 722 to determine whether the in- 
active time is less than 0.35 millisecond. If it is, a 
frame 1 flag is set in a step 728 identifying the incoming 

25 information as being associated with frame 1 and the 
interrupt loutine is exited in a step 730. In the event 
that the active time test in step 722 is not less than 
0.35 millisecond, in the step 724, the bit counter is 
cleared as well as the rolling code register and the fixed 

30 register and the return is exited in the step 726. If the 
active time is greater than 1 millisecond as tested in step 
720, a test is made in a step 732 to determine whether the 
active time is greater than 2.0 milliseconds. If it is 
not, the frame 2 flag is set in a step 734 and the routine 

35 is exited in step 730. If the active time is greater than 
2 milliseconds, the bit counter rolling code register and 
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fixed code register are cleared in step 724 and the routine 
is exited in step 726. 

In the event that the bit counter test in step 
712 indicates that the bit counter is not 0, control is 
5 transferred to step 736, as shown in FIG. 8A. Both the 
active and inactive periods are tested to determine whether 
they are less than 4.5 milliseconds. If either is not less 
than 4.5 milliseconds, the bit counter is cleared as well 
as the rolling code register and the fixed code registers. 

10 If both are equal to greater than 4.5 milliseconds, the bit 
counter is incremented and the active time is subtracted 
from the inactive time in the step 738, as shown in FIG. 
8D. In the step 740, the results of the subtraction are 
determined as to whether they are less than 0.38 milli- 

15 seconds. If they are, the bit value is set equal to zero 
in step 742 and control is transferred to a decision step 
743. If the results are not less than 0.38 milliseconds, 
a test is made in a step 744 to determine if they differ- 
ence between the active time and inactive time is greater 

20 than 0.38 milliseconds and control is then transferred to 
a step 746 setting the bit value equal to 2. Both of the 
bit values being set in steps 742 and 746 relate to a 
translation from the three- level trinary bits 0, 1 and 2 to 
a binary number. 

25 If the result of the step 744 is in the negative, 

the bit value is set equal to 1 in step 748. Control is 
then transferred to the step 743 to test whether the bit 
counter is set to an odd or an even number. If it is set 
to an odd number, control is transferred to a step 750 

30 where the fixed code, indicative of the fact that the bit 
is an odd numbered bit in the frame sequence, rather an 
even numbered bit, which would imply that it is one of the 
interleaved rolling code bits, is multiplied by three and 
then the bit value added in. 

35 If the bit counter indicates that it is an odd 

number trinary bit being processed, the existing rolling 
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code registers are multiplied by three and then the trinary 
bit value obtained from steps 742, 746 and 748 is added in. 
Whether step 750 or 752 occurs, the bit counter value is 
the tested in the step 754, as shown in FIG- 8E. If the 
5 bit counter value is greater than 21, the bit counter roll- 
ing code register and fixed code register are cleared in 
the step 758 and the routine is exited. If the bit counter 
value is less than 21, there is a return from the interrupt 
sequence in a step 756. If the bit counter value is equal 
10 to 21, indicating that a sink bit plus trinary data bits 
have been received, a test is made in a step 760 to 
determine whether the sink bit was indicative of a first or 
second frame, if it was indicative of a first frame, the 
bit counter is cleared and set up is done for the second 
15 frame following which there is a return from the routine in 
the step 762. In the event that the second frame is indi- 
cated as being received by the decision of step 760, the 
two frames have their rolling contributions added together 
to form the complete inverted rolling code. The rolling 
20 code is then inverted or mirrored to recover the rolling 
code counter value in the step 764. A test is made in the 
step 766 to determine whether the program mode has been 
set. If it has been set, control is transferred to a step 
768 where the code is compared to the last code received. 
25 If there is no match, as would be needed in order to get 
programming, then another code will be read until two 
successive codes match or the program mode is terminated. 
In a step 770, the codes are tested such that the fixed 
codes are tested for a match with a fixed code in non- 
30 volatile memory. If there is a match, the rolling portion 
is stored in the memory. If there is not, it is stored in 
the non-volatile memory. Control is then transferred to 
step 772, the program indicator is switched off, the 
program mode is exited and there is a return from the 
35 interrupt. In the event that the test of step 766 indi- 
cates that the program mode has not been set, the program 
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indicator is switched on in a step 774, as shown in FIG. 
8F. The codes are tested to determine whether there is a 
match for the fixed portion of the code in the step 776. 
If there is no match, the program indicator is switched off 
5 and the routine is exited in step 778. If there is a 
match, the counter which is indicative of the rolling code 
is tested to determine whether its value is greater than 
the stored rolling code by a factor or difference of less 
than 3,000 indicating an interval of 1,000 button pushes 

10 for the transmitter. If it is not, a test is made in the 
step 786 to determine whether the last transmission from 
the same transmitter is with a rolling code that is two to 
four less than the reception and, if true, is the memory 
value minus the received rolling code counter value greater 

15 than 1,000. If it is, control is transferred to a step 782 
switching off the program indicator and setting the opera- 
tion command word causing a commanded signal to operate the 
garage door operator. The reception time out timer is 
cleared and the counter value for the rolling code is 

20 stored in non-volatile memory, following which the routine 
is exited in the step 784. In the event that the differ- 
ence is not greater than 1,000, in step 786 there is an 
immediate return from the interrupt in the step 784. In 
the event that the counter test in the step 780 is posi- 

25 tive, steps 782 and 784 are then executed thereafter. 

While there has been illustrated and described 
a particular embodiment of the present invention, it will 
be appreciated that numerous changes and modifications will 
occur to those skilled in the art, and it is intended in 

3 0 the appended claims to cover all those changes and modifi- 
cations which fall within the true spirit and scope of the 
present invention. 



